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METHODS AND SYSTEM FOR TIME MANAGEMENT IN A 
SHARED MEMORY PARALLEL PROCESSOR COMPUTING 
ENVIRONMENT 

CROSS-REFERENCE TO RELATED APPLICATIONS 

5 This is the first application filed for the present 

invention, 

MICROFICHE APPENDIX 

Not applicable- 

TECHNICAL FIELD 

10 This invention relates, in general, to shared 

memory systems for use in parallel processing environments 
and, in particular, to methods and systems for time 
management in a shared memory parallel processor 
environment . 

15 BACKGROUND OF THE INVENTION 

The rapid growth of the Public Switched Telephone 
Network (PSTN), especially the rapid expansion of service 
features has strained the processing capacity of incumbent 
switching equipment. This is particularly the case in 

20 wireless telephony environments where messaging loads 
between mobile switching centers are great. As is well 
known, most incumbent switching equipment in the PSTN have 
processing architectures that are based on a single central 
control component that is responsible for all top level 

25 processing in the system. Such single-central-control- 
component-architectures provide the advantage to 
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application programmers of some simplification with respect 
to resource control, flow control and inter-process 
communication. However, single-central-control-component- 
architectures are subject to serious bottlenecks, due 
5 principally to the fact that each process is dependent on 
the capacity of the single core processor. There has 
therefore been an acute interest in developing parallel 
processor control for incumbent switching systems in order 
to improve performance and permit the addition of new 
10 processor-intensive service features. 

Parallel processor architectures are well known. 
However, the software written for parallel processor 
architectures is specifically designed to avoid processor 
conflicts while accessing shared resources, such as shared 

15 memory. This is accomplished by providing exclusive access 
to the shared memories using software semaphores or methods 
for locking memory access buses, and the like. However, 
incumbent switching systems in the PSTN were typically 
written for a central control component, and, in many 

20 cases, it is not economically feasible to rewrite the 
application code for a parallel processor architecture. 
Aside from the complexity of such a rewrite, the time and 
cost incurred to complete such a task is generally 
considered to be prohibitive. 

is known in the art that a shared memory 
parallel processor computing environment requires time 
management in order to ensure that any given process or 
class of processes is not permitted to monopolize processor 
time to the exclusion of other processes. It is also known 
30 that the time management must ensure that adequate 
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processing time is allocated to system-critical processes, 
such as payload processes. Time management is therefore a 
critical aspect of the control of a shared memory parallel 
processor computing environment. 

5 A time management algorithm for a shared memory 

parallel processor computing environment designed and 
implemented by the Assignee operated on the basis of timed 
hardware interrupts. At each interrupt, a timer queue was 
shuffled and process execution on each of the parallel 

10 processors was controlled. This is a common model of time 
management implemented in many prior art computing 
machines. One problem with time management based on- timed 
interrupts is that each interrupt consumes a certain 
proportion of system resources. If the interrupts are 

15 executed on a timed schedule, then at least some of the 
interrupts are invariably executed unnecessarily. Thus, 
system resources are wasted. Furthermore, in order to 
manage computing resources using timed interrupts, 
unnecessary operations are performed at each interrupt in 

20 order to ensure that processes do not monopolize resources. 
For example, each time an interrupt occurs, a status of a 
process being executed by each processor must be verified 
to ensure that the process has not used more than its share 
of computing resources. This occurs even if the process has 

25 just been started. 

While the timed interrupt represents a viable 
approach to time management in a shared memory parallel 
processor computing environment, it is not an optimal one 
because it fails to utilize system resources in a most 
30 efficient way, 
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It is therefore highly desirable to provide a 
method and system for time management processes in a shared 
memory, parallel processor computing environment that 
enhances performance by ensuring that access to computing 
5 resources is optimized. 

SUMMMIY OF THE INVENTION 

It is therefore an object of the invention to 
provide methods for time management in a shared memory 
parallel processing computing environment. 

^fl 10 It is a further object of the invention to provide 

m a shared memory parallel processor computing machine with 

ssfc. 

^ improved time management for process execution and timer 

■■:Tt" 

m queue management. 

H 

3 The invention therefore provides a method of 

15 managing execution time in a shared memory parallel 
processor computing environment in which a plurality of 
independent processors execute processes simultaneously. 
The method comprises steps of: defining a plurality of 
process classes and assigning each process to be executed 
20 to a one of the process classes; defining an execution time 
slice for each of the process classes; and permitting a 
process to be executed by a one of the processors without 
interruption until the execution time slice associated with 
the process class has expired. 

25 The method further comprises a step of enabling 

processes of at least one of the process classes to call a 
lock procedure during execution, which permits the process 
to continue to be executed without interrupt for a 



ssfc 
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predefined period of time after the time slice associated 
with the process class has expired. The at least one 
process is also enabled to call an unlock procedure to 
permit execution of the process to be terminated before the 
5 predefined period of time has expired. The predefined lock 
period may be an integer multiple of the time slice 
associated with the process class. Preferably, the lock 
procedure may be called repeatedly by the same process in 
order to simplify programming and accounting, 

10 The invention further provides a method of managing 

a timer queue in a shared memory parallel processor 
computing environment in which a plurality of independent 
processors execute processes simultaneously, the timer 
queue being used to queue processes in a wait state until a 

15 predetermined process removal time has expired, the method 
comprising steps of: defining a variable for storing a time 
at which a next process is to be removed from the timer 
queue; periodically examining the variable without 
generating a system interrupt to determine whether the time 

20 stored in the variable is less than or equal to an instant 
system time; removing each process from the timer queue 
which has an associated removal time that is less than or 
equal to the instant system time; and re-computing a time 
at which a next process is to be removed from the timer 

25 queue, and storing the re-computed time in the variable. 
Adding new processes to the timer queue further comprises 
steps of; computing a delay time specified by the process 
to be added to the queue; comparing the computed delay time 
with the time stored in the variable; if the computed delay 

30 time is less than the delay time stored in the variable. 
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replacing the delay time stored in the variable; and adding 
the process to the timer queue. 

The invention further provides a shared memory 
parallel processor computing machine in which a plurality 
of independent processors simultaneously execute processes, 
comprising: means for associating each process to be 
executed with a process class that defines rights and 
priorities associated with the process; means for 
associating an execution time slice with each of the 
process classes; and means for monitoring a process during 
execution to permit the process to be executed by a one of 
the processors without interruption until the execution 
time slice associated with the process class has expired. 
The means for permitting a process to be executed without 
interruption preferably comprises a time slice counter that 
is initialized to count representative of the predetermined 
execution time slice when the process is scheduled to be 
run, and is decremented at predetermined time intervals 
while the process is being executed. 

The computing machine further comprises a timer 
queue for queuing processes to be executed for a 
predetermined period of time, the timer queue being managed 
without interrupt until a process in the timer queue is 
ready to be transferred to a ready queue for execution by a 
one of the processors. A timer queue variable stores a time 
at which a next process is to be removed from the timer 
queue and placed in the ready queue. A scheduler 
periodically compares the timer queue variable with a 
current system time to determine when a next process is to 
be removed from the timer queue and placed in the ready 
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queue. The scheduler program is further adapted to compute 
a time that a process is to be removed from the timer queue 
when the process is to be added to the timer queue, and the 
scheduler is further adapted to update the timer queue 
5 variable if the timer queue variable is greater than the 
time computed by the scheduler program. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Further features and advantages of the present 
invention will become apparent from the following detailed 
10 description, taken in combination with the appended 
drawings, in which: 

FIG, 1 is a schematic diagram of a shared memory 
parallel processor computing environment that is known in 
the art; 

15 FIG. 2 is a schematic diagram illustrating a prior 

art process performed by a scheduler program while moving a 
process to be executed from a timer queue to one of a 
plurality of parallel processors in a shared memory 
parallel processor computing environment; 

20 FIG. 3 is a first process in accordance with the 

invention for managing a timer queue without timed 
interrupts; 

FIG. 4 is a flow diagram illustrating a second 
process in accordance with the invention for managing the 
25 timer queue without timed interrupts; 

FIGs. 5a-5d are time line diagrams illustrating a 
time management process in accordance with the invention by 
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which processes are enabled to be executed by a parallel 
processor without interruption for a predetermined, 
engineered period of time; 

FIG. 6 is a flow diagram illustrating the actions 
5 performed by the scheduler program while performing time 
management of process execution shown in FIGs. 5a-5d; and 

FIGs. 7a and 7b are flow diagrams illustrating 
actions performed by a lock procedure and an unlock 
procedure,! respectively; in accordance with the invention. 

10 It will be noted that throughout the appended 

drawings, like features are identified by like reference 
numerals . 



DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

This invention provides methods and systems for 
15 time management in a shared memory parallel processor 
computing environment. In accordance with the invention, a 
plurality of process classes are respectively allocated an 
execution time slice. Each process is associated with one 
of the classes so that each process inherits the execution 
20 time slice from the class of which the process is a member. 
The execution time slice determines how long a process may 
be executed by any one of the processors without interrupt. 
Certain of the classes are also enabled to extend the 
length of the execution time by calling a lock procedure 
25 that permits the process to continue processing without 
interrupt. The lock procedure sets a lock flag and 
initializes a lock clock that determines a length of time 
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that the process may continue to be executed without 
interrupt after the initial time slice has expired. 

The invention also provides a system and method for 
manaaing a timer queue. The timer queue is used to queue 
processes that request a predetermined time-out period 
prior to being placed in a ready queue for execution by one 
of the processors. In accordance with the method, the timer 
aueue is managed without interrupt by maintaining a timer 
queue time variable that indicates a time when a next 
process is to be removed from the timer queue and placed in 
the ready queue. A scheduler program periodically monitors 
the time variable and removes process (es) when the variable 
is less than or equal to a system time- When a new process 
is added to the timer queue, a removal time for the process 
15 is computed and the timer queue time variable is replaced 
with the removal time if the removal time, is less than the 
time variable. 

FIG. 1 is a schematic diagram of a parallel 
processor shared memory system 10, which is well known in 
20 the prior art. The system 10 includes a plurality of 
processors 12 (only four of which are shown) connected 
through an interconnect 14 to a main shared memory 16 made 
up of one or more memory modules (only one module is 
shown), in a manner well known in the art. One or more 10 
2. devices 16 are also connected to the interconnect 14. Such 
systems 10 are commonly equipped with redundant hardware 
components to increase fault tolerance, but redundancy is 
not essential to the invention and the redundant elements 
are not illustrated. Each processor 12 has a respective 
30 cache memory 20, that is also well known in the art. Each 
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memory module 16 includes a data memory and memory 
ownership control functionality, commonly implemented in 
firmware . 

FIG. 2 ik a schematic diagram illustrating a prior 
5 art process performed in the shared memory, parallel 
processor computing environment shown in FIG. 1 in which 
processes are moved from a timer queue 30 to ready 
\ queues 31. The timeV queue 30 is used to queue processes 
/ that request a specified time delay before being placed in 
10 one of the ready qWues 31 prior to execution by a 
respective processor 12\ When the specified time requested 
by a process placed in timer queue 30 has expired, a 
scheduler program (not sViown) moves the process from the 
timer queue 30 to a one of the ready queues 31, The ready 
15 queues 31 are arranged by class, in a manner well known in 
the art. Each process is ^sociated with a specific class 
and each class has associated rights and priorities which 
are peculiar to the class and determined by system 
engineers. The respective Aeady queues 31 are first-in 
20 first-out (FIFO) queues. Processes are added to a rear of 
the ready queue 31 and are mov4d to the processor 12 when 
they have advanced to a front of\the ready queue 31. As is 
well known in the art, processes Vnay be added to the ready 
queue 31 without first entering me timer queue 30. For 
25 the purposes of describing a first aspect of the invention, 
however, the movement of a process nrom the timer queue to 
execution by processor 12 is describeid. 

The scheduler adds a process to the timer queue 31 
(step A) on request by the process. The process specifies 
30 a specific duration of time for which it is to be timed-out 
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in the timer queue 30. The specific duration of time is 
specified, for example, by integer number of time units. 
The duration of each time unit is engineered in accordance 
with system requirements. When the scheduler adds a 
5 process to the timer queue 30, the scheduler multiplies the 
number of time units requested by the engineered duration 
of each time unit to derive the requested duration of time. 
The duration is expressed in a time unit (milliseconds, for 
example) . The scheduler then adds the time duration to a 
10 current time indicated by a system clock, for example, to 
derive a removal time for the process. The removal time 
indicates a time at which the process is to be removed from 
the timer queue 30 and moved to a one of the ready 
queues 31. When the time duration for a process in timer 
15 queue 30 has expired, the scheduler moves the process 
(step B) to a one of the ready queues dictated by a class 
with which the process is associated. As explained above, 
the process is moved to a tail of the ready queue 31 and, 
as soon as the process is shifted to a front of the ready 
20 queue 31, the process is selected (step C) and sent 
(step D) to an available one of the processors 12. The 
scheduler then monitors each process (step E) to determine 
when the process has completed processing, or has exceeded 
an allotted processing time. When a process is "switched 
25 out" of a processor 12, the process is either committed or 
rolled back (step F) , in a manner well known in the art of 
shared memory parallel processing. The entire process 
shown in FIG. 2 is generally managed using timed hardware 
interrupts, which trigger the scheduler program to perform 
30 the respective steps A-F in a cyclical series of steps that 
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is repeated at each timed interrupt. As is well 
understood, this tends to be wasteful of system resources, 

FIGs. 3 and 4 illustrate a method in accordance 
with the invention for managing the timer queue 30 without 
5 dependence on timed interrupts. In accordance with the 
invention, the scheduler calculates a time delay requested 
by a process, process A, for example, (step 32) . The 
calculated time delay (t^^) is compared with a global 
variable (tuvm) to determine whether tp, is less than tmin 

10 (step 33). If the calculated time delay is determined in 
step 33 to be greater than the global variable, the process 
is entered in the timer queue 30 (step 35) and the 
scheduler terminates the process. If, however, the 
scheduler determines in step 33 that the calculated time 

15 delay is less than the time indicated in the global 
variable (tmin)/ the global variable is set to the 
calculated time delay (step 34), before the process is 
entered in the timer queue 30 (step 35). The global 
variable (tnvin) is monitored once during each scheduler 

20 cycle, as shown at step 36 of FIG. 4. The scheduler 
program monitors the global variable by comparing a current 
system time with the global variable (tjTiin) / as shown at 
step 36, If the system time is not greater or equal to the 
global variable, the scheduler program moves on to perform 

25 other tasks required during its scheduled cycle. If, 
however, the scheduler program determines in step 36 that 
the system time is greater than or equal to the global 
variable (tmin) / the scheduler program forwards to ready 
queue 31 (FIG. 2) any process{es) waiting in the timer 

30 queue having an associated time delay that is less than or 
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equal to the current system time (step 37). After the 
process (es) have been moved from the timer queue 30 to the 
ready queues 31, the scheduler rearranges the timer queue 
(step 38), in a manner well known in the art. The timer 
5 queue 30 is therefore managed without timed interrupts, and 
system resources are thereby conserved. 

FIGs. 5a-5d are time line diagrams illustrating the 
time management of process execution in accordance with the 
invention. In accordance with the invention, each class of 

10 processes is allocated an engineered process execution time 
slice. The time slice has a predetermined duration during 
which the process is permitted to be executed by a one of 
the processors 12 without interruption. Every process is 
entitled to execute without interruption during the 

15 predetermined time slice allocated to its respective class. 
As is well understood in the art, certain processes 
executed by the processors 12 are system or function 
critical processes which must be permitted to execute to 
completion. At the same time, all processes must be 

20 policed to ensure that a rogue process does not consume 
unwarranted amounts of processor time. The methods in 
accordance with the invention ensure that processes are 
permitted to continue execution uninterrupted until a 
process has completed or a maximum engineered interval has 

25 been exceeded. 

FIG. 5a shows a time line 40 which schematically 
illustrates the execution of a process by one of the 
processors 12 in which processing terminates normally 
within a time slice 42 allocated to the process class. As 
30 shown in FIG. 5a, the process is "switched in" by the 
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scheduler, as shown at 44, and the processor 12 (FIG. 2) 
conunences execution of the process. The process is 
permitted to execute uninterrupted for the duration of the 
time slice 42. Throughout a duration of the time slice 42, 
5 the process does not call a procedure referred to as the 
"lock procedure", which permits the execution time to be 
extended. The lock procedure may not have been called for 
one of at least two reasons. First, the process may not be 
enabled to call lock. As noted above, only critical 
10 processes are enabled to call the lock procedure. Second, 
the process may have determined that it was able to 
complete within its allocated time slice 42, in which case 
lock would not be called. In either event, the process is 
switched out (at 46) where the time slice 42 ends, 

i5 Time management in accordance with the invention is 

accomplished by maintaining a local time counter 24 
(FIG, 1) at each of the respective processors 12. When a 
process is switched in (at 44), the scheduler program 
initializes the time counter 24 to a value representative 

20 of a duration of time slice 42. Thereafter, the 

processor 12 decrements the time counter 24 at regular 
intervals. When the time counter expires (is decremented 
to zero), the time counter causes a hardware interrupt 
which sets a time slice expired flag that prompts the 

25 scheduler to switch the process out and replace it with a 
next process. When the process is switched out, it is 
either committed or rolled back, as shown in FIG. 2 
(step F) . 

FIG. 5b shows a time line 40 in which a process 
30 calls the lock procedure in order to extend the time during 
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which the process is permitted to continue to execute. As 
shown in FIG, 5b, the process is switched in (at 47) and 
the time slice counter 24 is initialized by the scheduler 
program, At 48, the process determines that the lock 
5 procedure should be called, Triggers for calling the lock 
procedure may be implemented in a number of ways well known 
in the art. For example, the lock procedure may be 
triggered if the process computes a percentage completion 
that is below expectation, the process is delayed by a 

10 procedure call, the process must execute a specific program 
branch, etc. When lock is called, the lock procedure 
computes a lock interval 50, which is an engineered 
interval that may be based on an integer number of the 
duration of time slice 42, for example. The lock 

15 procedure sets a lock counter using the computed lock 
duration. When the time slice counter 24 expires at 52^ A 
time slice expired flag is set, but the process is not 
interrupted and continues to execute. In the example 
shown, the process fails to call an "unlock" procedure and 

20 is switched out by the scheduler program at 54 because the 
lock counter has expired. In accordance with the 
invention, processes are prevented from overconsuming 
system resources by being switched out after the expiration 
of the lock interval 50, regardless of whether processing 

25 has completed. 

FIG, 5c shows a time line 40 diagram to further 
illustrate the time management procedures in accordance 
with the invention. As shown in FIG. 5c, a process is 
switched in to one of the processors 12 at 56, and the time 
30 slice counter is initialized by the scheduler program to 
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the engineered interval associated with the class. At 58, 
the process calls the lock procedure and the lock procedure 
sets a lock flag and initializes the lock timer counter to 
the lock interval 50, The process continues uninterrupted 
5 processing until processing is completed and unlock is 
called, as shown at 60. Since the time slice interval 42 
has not expired, however, the process is not switched out 
until the expiration of the time slice counter causes the 
hardware interrupt, as shown at 62. 

10 FIG. 5d illustrates yet another aspect of the time 

management for process execution in accordance with the 
invention. As shown in FIG. 5d, a process is switched in 
to one of processors 12 (at 64) by the scheduler which 
initializes the time slice counter to the duration of the 

15 time slice 42 associated with the class of the process. At 
66, the process calls lock to ensure that it can continue 
processing, if required, past the expiration of the time 
slice 42. When expiration of the time slice counter 24 
(FIG. 1) causes a hardware interrupt at the processor 12, 

20 the time slice expired flag is set, as shown at 68. The 
process, however, continues to execute until its processing 
is completed and it calls the unlock procedure, as shown at 
70. When the unlock procedure is called, the lock flag is 
removed and the lock clock is stopped. Thereafter, the 

25 process is switched out by the scheduler program. 

FIG. 6 is a flow diagram that illustrates the 
actions of the scheduler during process time management in 
accordance with the invention. As shown in FIG. 6, the 
process begins when the scheduler program checks ready 
30 queues 31 (FIG. 2) to determine whether there is a process 
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ready to be run (step 80). If not, the scheduler program 
waits for a next cycle to again inspect the ready 
queues 31, If there is a process ready to be run, the 
scheduler program determines whether a one of the 
5 processors 12 (FIG. 2) is available (step 82). If all of 
the processors 12 are occupied, the scheduler program waits 
to a next scheduler interval to determine the availability 
of a processor 12. If a processor is available, the 
process is moved from the ready - queue 32 to the 
10 processor 12, and the processor is "switched in" in 
step 84. When the process is switched in, the scheduler 
program initializes the time slice clock timer (step 86), 
as described above. 

During each scheduling interval, the scheduling 

15 process checks the time slice clock counter at each of the 
respective processors 12 to determine whether the time 
slice clock has expired, as indicated by the time slice 
expired flag (see FIG. 5b). This check is cyclically 
repeated during each scheduling interval- If anv one of 

20 the time slice clocks has expired, the scheduler program 
determines whether the process is locked, as indicated by 
the process lock flag set by the lock procedure, as 
described above. The process lock flag may be, for 
example, a Boolean, as is well understood in the art. If 

25 the process is not locked, the process is switched out in 
step 92 and time management for that process ends. If the 
process is locked, the scheduler determines whether the 
lock clock has expired in step 94. If the lock clock has 
expired, the process is switched out in step 92, and the 

30 time management for that process ends. If the lock clock 
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has not expired, the scheduler returns to step 90 and at 
the next scheduling cycle determines whether the process is 
still locked. Steps 90-94 are repeated until the lock 
clock has expired, or the process has called the unlock 
5 procedure, whichever occurs first. 

FIG. 7a is a flow diagram that illustrates the 
principal actions of the lock procedure. When the lock 
procedure is called (step 100), the lock procedure first 
checks the lock flag to determine whether the process is 

10 already locked. In accordance with the invention, in order 
to simplify programming and accounting procedures^ lock 
calls may be nested. The nesting of lock calls does not 
affect the duration of the lock time interval (FIG. 5b) . 
If the process is already locked, as determined in 

15 step 102, the lock procedure proceeds to step 108 and 
simply increments a lock count before it returns. If the 
process is not already locked, however, the lock procedure 
sets a lock flag in step 104 and initializes and starts the 
lock timer in step 106. It then increments the lock count 

20 in step 108 before it returns. 

\ 

FIG. 7b is a flow diagram illustrating processes 
performed by the 'U^^^^^ procedure described above with 
reference to FIGs !\^5b-5d. In step 110, the unlock 
procedure is called b^y an executing process. As a first 

^5 action, the unlock procedure decrements the lock count 
(step 112) . The unlocft. procedure then examines the lock 
count to determine whether the lock count is greater than 
zero (step 114). If the \ock count is greater than 2ero, 
the process returns in step\ll4. If the lock count is not 

30 greater than zero, the unlocl\ process removes the lock flag 
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in step 115 and stops the lock timer in step 113. The 
unlock procedure then determines whether the time slice has 
expired in step 120. If the time slice has expired, the 
unlock procedure pauses in step 122. Otherwise, the unlock 
5 procedure returns in step 124. 

The invention therefore provides novel time 
management methods and a novel shared memory . parallel 
processor computing machine that incorporates the novel 
time management methods to provide a more robust and 

10 efficient shared memory parallel processor computing 
machine that is capable of higher throughputs. The shared 
memory parallel processor computing machine in accordance 
with the invention is particularly well adapted for use as 
a central processor for time division multiplexed telephone 

15 switches, but may likewise be utilized in any other 
computing application where high throughput of short 
duration processes is required. 

The embodiment (s ) of the invention described above 
is (are) intended to be exemplary only. The scope of the 
20 invention is therefore intended to be limited solely by the 
scope of the appended claims. 



